<!--
  ~ Licensed to the Apache Software Foundation (ASF) under one or more
  ~ contributor license agreements.  See the NOTICE file distributed with
  ~ this work for additional information regarding copyright ownership.
  ~ The ASF licenses this file to You under the Apache License, Version 2.0
  ~ (the "License"); you may not use this file except in compliance with
  ~ the License.  You may obtain a copy of the License at
  ~
  ~    http://www.apache.org/licenses/LICENSE-2.0
  ~
  ~ Unless required by applicable law or agreed to in writing, software
  ~ distributed under the License is distributed on an "AS IS" BASIS,
  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  ~ See the License for the specific language governing permissions and
  ~ limitations under the License.
  -->

<div class="flow-configuration-history-table flex-1 relative h-full w-full">
    <div class="listing-table overflow-y-auto absolute inset-0">
        <table
            mat-table
            [dataSource]="dataSource"
            matSort
            matSortDisableClear
            (matSortChange)="sortData($event)"
            [matSortActive]="initialSortColumn"
            [matSortDirection]="initialSortDirection">
            <!-- Date/Time Column -->
            <ng-container matColumnDef="timestamp">
                <th mat-header-cell *matHeaderCellDef mat-sort-header>
                    <div class="overflow-ellipsis overflow-hidden whitespace-nowrap">Date/Time</div>
                </th>
                <td mat-cell *matCellDef="let item" [title]="formatTimestamp(item)">
                    {{ formatTimestamp(item) }}
                </td>
            </ng-container>

            <!-- Id Column -->
            <ng-container matColumnDef="sourceId">
                <th mat-header-cell *matHeaderCellDef mat-sort-header>
                    <div class="overflow-ellipsis overflow-hidden whitespace-nowrap">Id</div>
                </th>
                <td mat-cell *matCellDef="let item" [title]="formatID(item)">
                    {{ formatID(item) }}
                </td>
            </ng-container>

            <!-- Name Column -->
            <ng-container matColumnDef="sourceName">
                <th mat-header-cell *matHeaderCellDef mat-sort-header>
                    <div class="overflow-ellipsis overflow-hidden whitespace-nowrap">Name</div>
                </th>
                <td mat-cell *matCellDef="let item" [title]="formatName(item)">
                    <span [class.neutral-color]="!item.action?.sourceName" [class.blank]="!item.action?.sourceName">{{
                        formatName(item)
                    }}</span>
                </td>
            </ng-container>

            <!-- Type Column -->
            <ng-container matColumnDef="sourceType">
                <th mat-header-cell *matHeaderCellDef mat-sort-header>
                    <div class="overflow-ellipsis overflow-hidden whitespace-nowrap">Type</div>
                </th>
                <td mat-cell *matCellDef="let item" [title]="formatType(item)">
                    {{ formatType(item) }}
                </td>
            </ng-container>

            <!-- Operation Column -->
            <ng-container matColumnDef="operation">
                <th mat-header-cell *matHeaderCellDef mat-sort-header>
                    <div class="overflow-ellipsis overflow-hidden whitespace-nowrap">Operation</div>
                </th>
                <td mat-cell *matCellDef="let item" [title]="formatOperation(item)">
                    {{ formatOperation(item) }}
                </td>
            </ng-container>

            <!-- User Column -->
            <ng-container matColumnDef="userIdentity">
                <th mat-header-cell *matHeaderCellDef mat-sort-header>
                    <div class="overflow-ellipsis overflow-hidden whitespace-nowrap">User</div>
                </th>
                <td mat-cell *matCellDef="let item" [title]="formatUser(item)">
                    {{ formatUser(item) }}
                </td>
            </ng-container>

            <!-- Actions Column -->
            <ng-container matColumnDef="actions">
                <th mat-header-cell *matHeaderCellDef></th>
                <td mat-cell *matCellDef="let item">
                    <div class="flex items-center justify-end gap-x-2">
                        <button
                            mat-icon-button
                            type="button"
                            [matMenuTriggerFor]="actionMenu"
                            class="h-16 w-16 flex items-center justify-center icon global-menu">
                            <i class="fa fa-ellipsis-v"></i>
                        </button>
                        <mat-menu #actionMenu="matMenu" xPosition="before">
                            @if (canRead(item)) {
                                <button mat-menu-item (click)="moreDetails(item)">
                                    <i class="fa fa-info-circle primary-color mr-2"></i>
                                    View Details
                                </button>
                            }
                        </mat-menu>
                    </div>
                </td>
            </ng-container>

            <tr mat-header-row *matHeaderRowDef="displayedColumns; sticky: true"></tr>
            <tr
                mat-row
                *matRowDef="let row; let even = even; columns: displayedColumns"
                [class.even]="even"
                (click)="select(row)"
                [class.unset]="!canRead(row)"
                [class.neutral-color]="!canRead(row)"
                [class.selected]="isSelected(row)"></tr>
        </table>
    </div>
</div>
